import 'package:flutter/material.dart';

class Imagedemo {
  static String imageRes = "images/image1.jpg";

  static Image getImage() {
    return Image(image: AssetImage(imageRes), width: 100.0);
  }

  /*
  Image也提供了一个快捷的构造函数
   */
  static Image getImage2() {
    return Image.asset(
      imageRes,
      width: 100.0,
    );
  }

  static var imageUrl =
      "https://gimg2.baidu.com/image_search/src=http%3A%2F%2Fimage109.360doc.com%2FDownloadImg%2F2024%2F05%2F1018%2F283462633_4_20240510061136195&refer=http%3A%2F%2Fimage109.360doc.com&app=2002&size=f9999,10000&q=a80&n=0&g=0n&fmt=auto?sec=1722493207&t=eddba6e143d76bc20ff55760ef28580d";

  static Image getImage3() {
    return Image(
      image: NetworkImage(imageUrl),
      width: 100.0,
    );
  }

  static Image getImage4() {
    return Image.network(
      imageUrl,
      width: 100.0,
    );
  }

  static ListView getImageListView() {
    return ListView(
      children: [
        getItem(BoxFit.fill),
        getItem(BoxFit.contain),
        getItem(BoxFit.cover),
        getItem(BoxFit.fitWidth),
        getItem(BoxFit.fitHeight),
        getItem(BoxFit.scaleDown),
        getItem(BoxFit.none),
        getImage5(),
      ],
    );
  }

  /*
  color和 colorBlendMode：在图片绘制时可以对每一个像素进行颜色混合处理，color指定混合色，而colorBlendMode指定混合模式
   */
  static Image getImage5() {
    return Image.network(
      imageUrl,
      width: 100.0,
      height: 100,
      color: Colors.blue,
      colorBlendMode: BlendMode.difference,
    );
  }

  static Image getItem(BoxFit fit) {
    return Image.asset(
      imageRes,
      width: 180.0,
      height: 180,
      fit: fit,
    );
  }

/*
  const Image({
  ...
  this.width, //图片的宽
  this.height, //图片高度
  this.color, //图片的混合色值
  this.colorBlendMode, //混合模式
  this.fit,//缩放模式
  this.alignment = Alignment.center, //对齐方式
  this.repeat = ImageRepeat.noRepeat, //重复方式
  ...

  width、height：用于设置图片的宽、高，当不指定宽高时，图片会根据当前父容器的限制，尽可能的显示其原始大小，如果只设置width、height的其中一个，那么另一个属性默认会按比例缩放，但可以通过下面介绍的fit属性来指定适应规则。

fit：该属性用于在图片的显示空间和图片本身大小不同时指定图片的适应模式。适应模式是在BoxFit中定义，它是一个枚举类型，有如下值：

fill：会拉伸填充满显示空间，图片本身长宽比会发生变化，图片会变形。
cover：会按图片的长宽比放大后居中填满显示空间，图片不会变形，超出显示空间部分会被剪裁。
contain：这是图片的默认适应规则，图片会在保证图片本身长宽比不变的情况下缩放以适应当前显示空间，图片不会变形。
fitWidth：图片的宽度会缩放到显示空间的宽度，高度会按比例缩放，然后居中显示，图片不会变形，超出显示空间部分会被剪裁。
fitHeight：图片的高度会缩放到显示空间的高度，宽度会按比例缩放，然后居中显示，图片不会变形，超出显示空间部分会被剪裁。
none：图片没有适应策略，会在显示空间内显示图片，如果图片比显示空间大，则显示空间只会显示图片中间部分。
})
   */
}
